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Question: 1 


Note: This question is part of a series of questions that use the same scenario. For your convenience, 
the scenario is repeated in each question. Each question presents a different goal and answer 
choices, but the text of the scenario is exactly the same in each question in this series. 


You query a database that includes two tables: Project and Task. The Project table includes the 
following columns: 


| Columnname | Datatype | Notes O| 
|ProjectName | varchar(100) | S 
|StartTime | datetime2(7) | o 


| Columnname | Datatype | Notes | 


A null value indicates the task is not assigned to a 
specific project. 


Projectid int 


StartTime datetime2(7) | WNY O 
datetime2(7 A null value indicates the task is not completed yet. 


int identifies the owner of the task. 


You plan to run the following query to update tasks that are not yet started: 
UPDATE Task SET StartTime = GETDATE(} WHERE StartTime IS NULL 


You need to return the total count of tasks that are impacted by this UPDATE operation, but are not 
associated with a project. 


What set of Transact-SQL statements should you run? 
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JA DECLARE @startedTasks TABLE ({ProjectId int) 
UPDATE Task SET StartTime = GETDATE() OUTPUT deleted.ProjectId INTO @startedTasks WHERE StartTime is NULL 


SELECT COUNT(*) FROM @startedTasks WHERE ProjectId IS NOT NULL 


OB DECLARE @startedTasks TABLE(TaskId int, ProjectId int) 
UPDATE Task SET StartTime = GETDATE() OUTPUT deleted.TaskId, deleted.ProjectId INTO @startedTasks 
WHERE StartTime is NULL 
SELECT COUNT(*) FROM @startedTasks WHERE ProjectiId IS NULL 


B. 
Oc DECLARE @startedTasks TABLE (TaskId int) 
UPDATE Task SET StartTime = GEIDATE() OUTPUT inserted.TaskId, INTO @startedTasks WHERE StartTime is NULL 
c SELECT COUNT(*) FROM @startedTasks WHERE TaskId IS NOT NULL 
OD DECLARE @startedTasks TABLE (TaskId int) 
UPDATE Task SET StartTime = GETDATE() OUTPUT deleted.TaskId, INTO @startedTasks WHERE StartTime is NULL 
D SELECT COUNT(*) FROM @startedTasks WHERE TaskId IS NOT NULL 
A. Option A 
B. Option B 
C. Option C 
D. Option D 
Answer: B 
Explanation: 


The WHERE clause of the third line should be WHERE ProjectID IS NULL, as we want to count the 
tasks that are not associated with a project. 


Question: 2 


HOTSPOT 

Note: This question is part of a series of questions that use the same scenario. For your convenience, 
the scenario is repeated in each question. Each question presents a different goal and answer 
choices, but the text of the scenario is exactly the same in each question in this series. 

You query a database that includes two tables: Project and Task. The Project table includes the 
following columns: 


int 
int 


This is a unique identifier for a project. 


|Projectid [int 
A null value indicates the project is not finished yet. 
lUserid — dint ooo o Identifies the owner of the project. 
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—Solumnname | —Ostatype | Noes 
Teska [m This isa unique identifier foratase — | 
Lint | Each | Each task may or may not have a parent task. | may or may not have a parent Fock 


, A null value indicates the task is not assigned to a 
Projectid 
me project. 


StartTime datetime2(7 
—_ 7 A E value indicates the task is not completed yet. 
identifies the owner of the task. 


You need to identify the owner of each task by using the following rules: 

- Return each task’s owner if the task has an owner. 

- If a task has no owner, but is associated with a project that has an owner, return the project’s 
owner. 

- Return the value -1 for all other cases. 

How should you complete the Transact-SQL statement? To answer, select the appropriate Transact- 
SQL segments in the answer area. 


Answer Area 


SELECT T.TaskIid, T.TaskNane, 


iw ¢ |W ) AS OwnerUserId 
ISNULL T.Userld, P.Userld, -1 
COALESCE P. Userld, T.Userld, -1 
CHOOSE -1, PUserld, T.Userld 
-1, T.Userld, PUserld 


FROM Task T 
lw Project P ON T.Projectid = P.Projectid 


INNER JOIN 
LEFT JOIN 
RIGHT JOIN 


Answer: 


COALESCE 
T.UsenD, p.UseriD, -1 
LEFT JOIN 


Explanation: 

Box 1: COALESCE 

COALESCE evaluates the arguments in order and returns the current value of the first expression that 
initially does not evaluate to NULL. 

Box 2: T.UserlD, p.UserlD, -1 

- Return each task’s owner if the task has an owner. 

- If a task has no owner, but is associated with a project that has an owner, return the project’s 
owner. 

- Return the value -1 for all other cases. 

Box 3: LEFT JOIN 
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The LEFT JOIN keyword returns all rows from the right table (table2), with the matching rows in the 
left table (table1). The result is NULL in the left side when there is no match. Here the right side could 
be NULL as the projectID of the task could be NULL. 

References: 

https://msdn.microsoft.com/en-us/library/ms190349.aspx 
http://www.w3schools.com/Sql/sql_join_right.as 


Question: 3 


DRAG DROP 

Note: This question is part of a series of questions that use the same scenario. For your convenience, 
the scenario is repeated in each question. Each question presents a different goal and answer 
choices, but the text of the scenario is exactly the same in each question in this series. 

You query a database that includes two tables: Project and Task. The Project table includes the 
following columns: 


Column name | Datatype __ 


Projectid int This is a unique identifier for a project. 


ProjectName varchar(100) 
StartTime 


EndTime datetime2(7 A null value indicates the project is not finished yet. 


Identifies the owner of the project. 


| Columnname | Datatype | Notes č  — | 


A null value indicates the task is not assigned to a 


Projectid int Be ; 
specific project. 


StartTime datetime2(7) | o O 
datetime2(7 A null value indicates the task is not completed yet. 
identifies the owner of the task. 


When running an operation, you updated a column named EndTime for several records in the Project 
table, but updates to the corresponding task records in the Task table failed. 

You need to synchronize the value of the EndTime column in the Task table with the value of the 
EndTime column in the project table. The solution must meet the following requirements: 

* Ifthe EndTime column has a value, make no changes to the record. 

* Ifthe value of the EndTime column is null and the corresponding project record is marked as 
completed, update the record with the project finish time. 

Which four Transact-SQL segments should you use to develop the solution? To answer, move the 
appropriate Transact-SQL segments from the list of Transact-SQL segments to the answer area and 
arrange them in the correct order. 
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Transact-SQL segments 


P.EndTime IS NOT NULL AND 
T.EndTime is NULL 


ndTime IS NULL AND T.EndT 


* 


INNER JOIN Project AS P ON 
= P.Projectid 


= bens 
i Proje 


INNER JOIN Task AS T ON T.UseriId = 
P.UserId 
UPDATE P SET P.EndTime = T.EndTime 


Answer Area 


Answer Area 


=| © 
© 


ctld 


Page 6 


OO 


Answer: 


UPDATE I SET T.EndTime = P.EndTirme | 
mnom Task AS T | 


© INNER JOIN Project AS P ON T.Projectid | 


= P.Projectid 


T.EndTime is NULL 


Explanation: 


WHERE F.EndTime IS WOT NULL AND 


OO 


Box 1: UPDATE T SET T.EndTime = P.EndTime 
We are updating the EndTime column in the Task table. 


Box 2: FROM Task AS T 
Where are updating the task table. 


Box 3:INNER JOIN Project AS P on T.ProjectID = P.ProjectID 

We join with the Project table (on the ProjectID columnID column). 
Box 4: WHERE P.EndTime is NOT NULL AND T.EndTime is NULL 

We select the columns in the Task Table where the EndTime column in the Project table has a value 


(NOT NULL), but where it is NULL in the 
References: 


Task Table. 


https://msdn.microsoft.com/en-us/library/ms177523.aspx 
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Question: 4 


DRAG DROP 

You need to create a stored procedure that meets the following requirements: 

*Produces a warning if the credit limit parameter is greater than 7,000 

*Propagates all unexpected errors to the calling process 

How should you complete the Transact-SQL statement? To answer, drag the appropriate Transact- 
SQP segments to the correct locations. Each Transact-SQL segments may be used once, more than 
once, or not at all. You may need to drag the split bar between panes or scroll to view content. 


Transact-SQL segments Answer Area 
RAISERROR ('Warning: Credit CREATE PROC dbo UpdateCustomer @CustomerID int, €@Creditlimit money 
limit is over 7,000!’, 16, 1} AS 

SEGIN 


RAISERROR {’Warning: Cred 
RATSERROR Karning TRD DECLARE @ErrorMessage varchar {1000} 


limis ver 7,000!°, 10, 1} 
= 22 ove a 2 BEGIN TRY 


THROW 52000, ‘Warning: Credit 
limit is over 7,000!’, 1 pd T Transact-SQL segment 
le 
o 
THROW |% UPDATE dbo.Customer 
í SET CreditLimit = @CreditLimis 
RAISERROR {(@ErrorMessage,; 16, 1) WHERE CustomerID = #CustdnerIņ 
END TRY 
BEGIN CATCH 
RAISERROR {@ErrorMessage, l0, 1) SET @ErrorMessage = ERROR_MESSAGE() 
: INSERT INTO dbo-ErrorLog(ApplicationiD, [Date], ErrorMessage 
VALUES (1, GETDATE{), @ErrorMessage) 


(THROW 51000, €ErrorMessage, 1 
ay Transact-SQL segment 

RAISERROR (GErrorMessage, 20, 1) 

WITH LOG | 
— — END CATCH 


Answer: 
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Explanation: 

Box 1: THROW 51000, 'Warning: Credit limit is over 7,000!",1 

THROW raises an exception and transfers execution to a CATCH block of a TRY...CATCH construct in 
SQL Server. 

THROW syntax: 

THROW [ { error_number | @local_variable }, 

{ message | @local_variable }, 

{state | @local_variable } ] 

[;] 

Box 2: RAISERROR (@ErrorMessage, 16,1) 

RAISERROR generates an error message and initiates error processing for the session. RAISERROR 
can either reference a user-defined message stored in the sys.messages catalog view or build a 
message dynamically. The message is returned as a server error message to the calling application or 
to an associated CATCH block of a TRY...CATCH construct. New applications should use THROW 
instead. 

Severity levels from 0 through 18 can be specified by any user. Severity levels from 19 through 25 can 
only be specified by members of the sysadmin fixed server role or users with ALTER TRACE 
permissions. For severity levels from 19 through 25, the WITH LOG option is required. 

On Severity level 16. Using THROW to raise an exception 

The following example shows how to use the THROW statement to raise an exception. 

Transact-SQL 

THROW 51000, 'The record does not exist.', 1; 

Here is the result set. 

Msg 51000, Level 16, State 1, Line 1 

The record does not exist. 

Note: RAISERROR syntax: 

RAISERROR ( { msg_id | msg_str | @local_variable } 

{ ,severity ,state } 
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[ argument [,...n]]) 

[ WITH option [,...n ] ] 

Note: The ERROR_MESSAGE function returns the message text of the error that caused the CATCH 
block of a TRY...CATCH construct to be run. 

References: 

https://msdn.microsoft.com/en-us/library/ms178592.aspx 
https://msdn.microsoft.com/en-us/library/ms190358.aspx 
https://msdn.microsoft.com/en-us/library/ee677615.aspx 


Question: 5 


DRAG DROP 
You need to create a stored procedure to update a table named Sales.Customers. The structure of the 
table is shown in the exhibit. (Click the exhibit button.) 


Sales.Customers 
a Og Columns 
custid (PK, int, not null) 
companyname (nvarchar(40), not null) 
contactname (nvarchar(30), not null) 
econtacttitle (nvarchar(30), not null) 
address (nvarchar(60), not null) 
city (nvarchar(15), not null) 
region (nvarchar(15), null) 
postalcode (nvarchar(10), null) 
country (nvarchar(15), not null) 
phone (nvarchar(24), not null) 
fax (nvarchar(24), null) 


? 
fal 
E 
E 
(al 
fal 
ET) 
E 
E 


bel 


The stored procedure must meet the following requirements: 

- Accept two input parameters. 

- Update the company name if the customer exists. 

- Return a custom error message if the customer does not exist. 

Which five Transact-SQL segments should you use to develop the solution? To answer, move the 
appropriate Transact-SQL segments from the list of Transact-SQL segments to the answer area and 
arrange them in the correct order. 

NOTE: More than one order of answer choices is correct. You will receive credit for any of the correct 
orders you select. 
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Transact-SQL segments Answer Area 


CREATE PROCEDURE Sales .ModCompanyName 


@custID int, @newname nvarchar(40) AS 
d 


IF NOT EXISTS (SELECT custid FROM 
Sales. Customers WHERE custid = @custID) | 
a 


UPDATE Sales.Customers ] < 
SET companyname = @newname Q 


WHERE custid = @custID 


BEGIN THROW 55555, ‘The customer ID 
does not exist’, 1 END 


‘UPDATE Sales.Customers 
SET companyname = &custID i 
WHERE custid = ĝnewname 

IF EXISTS (SELECT custid FROM 
Sales.Customers 

WHERE custid = @custID) 


romac TRANSACTION 


—i 


Answer: 


Question: 6 


You need to create an indexed view that requires logic statements to manipulate the data that the 
view displays. 
Which two database objects should you use? Each correct answer presents a complete solution. 
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A. a user-defined table-valued function 
B. a CRL function 

C. a stored procedure 

D. a user-defined scalar function 


Answer: A,C 


Question: 7 


Note: This question is part of a series of questions that use the same scenario. For your convenience, 
the scenario is repeated in each question. Each question presents a different goal and answer 
choices, but the text of the scenario is exactly the same in each question on this series. 

You have a database that tracks orders and deliveries for customers in North America. 

System versioning is enabled for all tables. The database contains the Sales.Customers, 
Application.Cities, and Sales.CustomerCategories tables. 

Details for the Sales.Customers table are shown in the following table: 


Customerld primary ke 


f foreign key to the 
Cust Cat Id 
papel eis Sales.CustomerCategories table 
PostalCityID foreign key to the Application.Cities table 
DeliveryCityID foreign key to the Application.Cities table 
i 


AccountOpenedDate does not allow values 
StandardDiscountPercentage M does not allow values 


CreditLimit decimal(18,2 null values are permitted 


IsOnCreditHold does not allow values 


DeliveryLocation geography does not allow values 
PhoneNumber does not allow values 


. , does not allow values, GENERATED 
ValidFrom datetime2(7) ALWAYS AS ROW START 

. , does not allow values, GENERATED 
ValidTo datetime2(7) ALWAYS AS ROW END 


Details for the Application.Cities table are shown in the following table: 


| Column | Datatype | 
CityID 
LatestRecordedPopulation null values are permitted 


Details for the Sales.CustomerCategories table are shown in the following table: 


| Column | Datatype | Notes O| 
CustomerCategoryID 


nt 
nt 
nt 
nt 
nt 
bit 


CustomerCategoryName nvarchar(50 does not allow null values 
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You need to create a query that meets the following requirements: 

- For customers that are not on a credit hold, return the CustomerID and the latest recorded 
population for the delivery city that is associated with the customer. 

- For customers that are on a credit hold, return the CustomerID and the latest recorded population 
for the postal city that is associated with the customer. 

Which two Transact-SQL queries will achieve the goal? Each correct answer presents a complete 
solution. 


A SELECT CustomerID, LatestRecordedPopulation 
FROM Sales.Customers 
CROSS JOIN Application.Citites 
WHERE {isOnCreditHold = 0 AND DeliveryCityID = CityID) 
OR (IsOnCreditHold = 1 AND PostalCityID = CityID) 


B SELECT CustomerID, LatestRecordedPopulation 
FROM Sales.Customers 
INNER JOIN Application.Citites AS A 
ON A.CityID = IIF(isOnCreditHold = 0, DeliveryCityID; PostalCityID) 
c SELECT CustomerID, ISNULL(A.LatestRecordedPopulation, B.LatestRecorded Population) 
FROM Sales.Customers 
INNER JOIN Application.Citites AS A ON A.CityID = DeliveryCityiD 
INNER JOIN Application.Citites AS B ON B.CityID = PostalCityID 
WHERE IsOnCreditHoid = 0 
D SELECT CustomerID, LatestRecordedPopulation, 
IIF(IsOnCreditHold = 0, DeliveryCityID, PostalCityID) As. CityId 
FROM Salies.Customers 
INNER JOIN Application.Citites AS A ON A.CityID = Citylid 
A. OptionA 
B. Option B 
C. Option C 
D. Option D 
Answer: AB 
Explanation: 


Using Cross Joins 

A cross join that does not have a WHERE clause produces the Cartesian product of the tables 
involved in the join. The size of a Cartesian product result set is the number of rows in the first table 
multiplied by the number of rows in the second table. 

However, if a WHERE clause is added, the cross join behaves as an inner join. 

B: You can use the IIF in the ON-statement. 

IIF returns one of two values, depending on whether the Boolean expression evaluates to true or 
false in SQL Server. 

References: 

https://technet.microsoft.com/en-us/library/ms190690(v=sql.105).aspx 


https://www.certkillers.net 


Questions & Answers PDF Page 13 


/msdn.microsoft.com, 


https:/, /en-us/library/hh213574.aspx 
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Question: 8 


DRAG DROP 

Note: This question is part of a series of questions that use the same scenario. For your convenience, 
the scenario is repeated in each question. Each question presents a different goal and answer 
choices, but the text of the scenario is exactly the same in each question in this series. 

Start of repeated scenario 

You have a database that contains the tables shown in the exhibit. (Click the Exhibit button.) 


Column Name Data Type Allow Nulls Column Name Data Type Allow Nulls 
2 SalesSummaryKey int 7 EmployeelD smallint 
SalesYear smallint EmployeeCode char(6) 
SalesQuarter smallint FirstName varchar(30) 
SalesMonth smallint MiddleName varchar(30) 
SalesDate date LastName varchar(40) 
ProductCode char(12) Title varchar(50) 


CustomerCode char(6) ManageriD smallint 


o 
E 
z) 
4 
o 
o 
z 
o 


EmployeeCode char(6) 
RegionCode char(2) 


SalesAmount money 


DON RBDoOBoOoaO0 


You review the Employee table and make the following observations: 

e Every record has a value in the ManagerlID except for the Chief Executive Officer (CEO). 

e The FirstName and MiddleName columns contain null values for some records. 

e The valid values for the Title column are Sales Representative, Manager, and CEO. 

You review the SalesSsummary table and make the following observations: 

e The ProductCode column contains two parts: The first five digits represent a product code, and the 
last seven digits represent the unit price. The unit price uses the following pattern: ####.##. 

e You observe that for many records, the unit price portion of the ProductCode column contains 
values. 

e The RegionCode column contains NULL for some records. 

e Sales data is only recorded for sales representatives. 

You are developing a series of reports and procedures to support the business. Details for each report 
or procedure follow. 

Sales Summary report: This report aggregates data by year and quarter. The report must resemble 
the following table. 


2000.00 
3500.00 500.00 
3500.00 1000.00 
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Sales Manager report: This report lists each sales manager and the total sales amount for all 
employees that report to the sales manager. 

Sales by Region report: This report lists the total sales amount by employee and by region. The report 
must include the following columns: EmployeeCode, MiddleName, LastName, RegionCode, and 
SalesAmount. 

If MiddleName is NULL, FirstName must be displayed. 

If both FirstName and MiddleName have null values, the world Unknown must be displayed. If 
RegionCode is NULL, the word Unknown must be displayed. 

Report1: This report joins data from SalesSummary with the Employee table and other tables. You 
plan to create an object to support Report1. The object has the following requirements: 

e be joinable with the SELECT statement that supplies data for the report 

e can be used multiple times with the SELECT statement for the report 

e be usable only with the SELECT statement for the report 

e not be saved as a permanent object 

Report2: This report joins data from SalesSummary with the Employee table and other tables. You 
plan to create an object to support Report1. The object has the following requirements: 

e be joinable with the SELECT statement that supplies data for the report 

e can be used multiple times for this report and other reports 

e accept parameters 

e be saved as a permanent object 

Sales Hierarchy report. This report aggregates rows, creates subtotal rows, and super-aggregates 
rows over the SalesAmount column in a single result-set. The report uses SaleYear, SaleQuarter, and 
SaleMonth columns as a hierarchy. The result set must not contain a grand total or cross-tabulation 
aggregate rows. 

Current Price Stored Procedure: This stored procedure must return the unit price for a product when 
a product code is supplied. The unit price must include a dollar sign at the beginning. In addition, the 
unit price must contain a comma every three digits to the left of the decimal point, and must display 
two digits to the left of the decimal point. The stored procedure must not throw errors, even if the 
product code contains invalid data. 

End of Repeated Scenario 

You need to create the query to supply data for the Sales Hierarchy report. 

Which Transact-SQL keyword should you use for each operation? To answer, drag the appropriate 
Transact-SQL keywords to the correct operations. Each action may be used once, more than once or 
not at all. You may drag the split bar between panes or scroll to view content. 


https://www.certkillers.net 


Questions & Answers PDF Page 16 


Transact-SQL keywords Answer Area 
GROUP BY Operation Transact-SQL keyword 
= 
Aggregation Transact-SQL keyword 
ROLLUP 
3 a 
Grouping - ceyw 
CHECKSUM _AGG © ping Transact-SQL keyword A 
Filtering Transact-SQL keyword 
~ |] @ Jm, @ 
GROUPING_ID 
GROUPING 
Answer: 


Operation Transact-SQL keyword 


Aggregation | SUM 
© Grouping | GROUP BY A 
O Filtering | ROLLUP Q 


Reference: 
https://docs.microsoft.com/en-us/sql/t-sql/functions/sum-transact-sql?view=sql-server-ver15 


https://www.sqlservertutorial.net/sql-server-basics/sql-server-rollu 


Question: 9 


Note: This question is part of a series of questions that use the same scenario. For your convenience, 
the scenario is repeated in each question. Each question presents a different goal and answer 
choices, but the text of the scenario is exactly the same in each question on this series. 

You have a database that tracks orders and deliveries for customers in North Americ 

a. System versioning is enabled for all tables. The database contains the Sales.Customers, 
Application.Cities, and Sales.CustomerCategories tables. 

Details for the Sales.Customers table are shown in the following table: 
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| Column | Datatype | Notes | 
Customerld 


; foreign key to the 
Cust Cat Id t 
Sales,CustomerCategories table 


PostalCityID foreign key to the Application.Cities table 
DeliveryCityID foreign key to the Application.Cities table 


int 


ValidFrom datetime2(7) does not allow values, GENERATED 


ALWAYS AS ROW START 


. . does not allow values, GENERATED 
ValidTo datetime2(7) ALWAYS AS ROW END 


Details for the Application.Cities table are shown in the following table: 


| Column | Datatype | Notes | 
CityID 
LatestRecordedPopulation null values are permitted 


Details for the Sales.CustomerCategories table are shown in the following table: 


| Column | Datatype | Notes O| 
CustomerCategoryID 


CustomerCategoryName nvarchar{50 does not allow null values 


You discover an application bug that impacts customer data for records created on or after January 1, 
2014. In order to fix the data impacted by the bug, application programmers require a report that 
contains customer data as it existed on December 31, 2013. 

You need to provide the query for the report. 

Which Transact-SQL statement should you use? 
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A DECLARE @sdate DATETIME, @edate DATETIME 
SET @sdate = DATEFROMPARTS (2013, 12, 31) 
set @edate = DATEADD(d, 1, @sdate} 
SELECT * FROM Sales.Customers FOR SYSTEM TIME ALL 
WHERE ValidFrom > @sdate AND ValidTIo < f#edate 


B DECLARE @sdate DATETIME, @edate DATETIME 
SET @sdate = DATEFROMPARTS (2013, 12, 31) 
set edate = DATEADD(d, -l, @sdate 
SELECT * FROM Sales.Customers FOR SYSTEM_TIME BETWEEN @sdate AND @edate 


oO 
=) 


ECLARE @date DATE 
SET @date = DATEFROMPARTS (2013, 12, 31) 
SELECT * FROM Sales.Customers FOR SYSTEM_TIME AS OF @date 


D DECLARE @date DATE 
SET date = DATEFROMPARTS (2013, 12, 31) 
SELECT * FROM Sales.Customers WHERE @date BETWEEN ValidFrom AND ValidTo 


A. Option A 
B. Option B 
C. Option C 
D. Option D 


Answer: D 


Explanation: 

The datetime datetype defines a date that is combined with a time of day with fractional seconds 
that is based on a 24-hour clock. 

The DATEFROMPARTS function returns a date value for the specified year, month, and day. 
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Question: 10 


DRAG DROP 

Note: This question is part of a series of questions that use the same scenario. For your convenience, 
the scenario is repeated in each question. Each question presents a different goal and answer 
choices, but the text of the scenario is exactly the same in each question on this series. 

You have a database that tracks orders and deliveries for customers in North Americ 

a. System versioning is enabled for all tables. The database contains the Sales.Customers, 
Application.Cities, and Sales.CustomerCategories tables. 

Details for the Sales.Customers table are shown in the following table: 


| Column | Datatype | Notes č  — | 
Customerld int 


int o 
: foreign key to the 
DeliveryLocation 


ValidFrom datetime2(7) does not allow values, GENERATED 


ALWAYS AS ROW START 


. : does not allow values, GENERATED 
ValidTo datetime2(7) ALWAYS AS ROW END 


Details for the Application.Cities table are shown in the following table: 


| Column | Datatype | Notes 
CityID 
LatestRecordedPopulation null values are permitted 


Details for the Sales.CustomerCategories table are shown in the following table: 


| Column | Datatype | Notes č 


CustomerCategoryID 
CustomerCategoryName does not allow null values 


You are creating a report to measure the impact of advertising efforts that were designed to attract 
new customers. The report must show the number of new customers per day for each customer 
category, but only if the number of new customers is greater than five. 

You need to write the query to return data for the report. 
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How should you complete the Transact-SQL statement? To answer, drag the appropriate Transact-SQL 
segments to the correct locations. Each Transact-SQL segment may be used once, more than once, or 
not at all. You may need to drag the split bar between panes or scroll to view content. 


Transact-SQL segments Answer Area 
CAST {Cust .AccountOpenedDate SELECT Count (Cust.CustomerId), CustCat.CustomerCategoryName, Transact-SQL segment 
DATE) ae. -E 
FROM Sales.Customers AS Cust 
DATEPART (day, INNER JOIN Sales.CustomerCategories AS CustCat 
Cust -AccountOpenedDate} ON Cust.CustomerCategoryID = CusCat.CustcomerCategoryID 
HAVING e Transact-SQL segment CustCat.CustomerCategoryName, Transact-SQL segment 
e | L i | 
m e = 1 as | 1 
WHERE e Transact-SQL segment Transact-SQL segment >5 
Bi 
COUNT (Cust .CustomerId) 
eee 
MAX (Cust CustomerID) 
E 
RANK 
J 
GROUP BY 
Answer: 
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